<template>
  <div class="echarts-gauge" ref="chart"></div>
</template>

<script>
import * as echarts from 'echarts';

export default {
  data() {
    return {
      myChart: null
    };
  },
  mounted() {
    this.initChart();
  },
  methods: {
    initChart() {
      this.myChart = echarts.init(this.$refs.chart);
      const option = {
        series: [
          {
            type: 'gauge',
            axisLine: {
              lineStyle: {
                width: 15, // 调整线条宽度
                color: [
                  [0.3, '#67e0e3'],
                  [0.7, '#37a2da'],
                  [1, '#fd666d']
                ]
              }
            },
            pointer: {
              itemStyle: {
                color: 'auto'
              }
            },
            axisTick: {
              distance: -15, // 调整刻度线的距离
              length: 5, // 调整刻度线的长度
              lineStyle: {
                color: '#fff',
                width: 1 // 调整刻度线的宽度
              }
            },
            splitLine: {
              distance: -15, // 调整分割线的距离
              length: 15, // 调整分割线的长度
              lineStyle: {
                color: '#fff',
                width: 2 // 调整分割线的宽度
              }
            },
            axisLabel: {
              color: 'inherit',
              distance: 20, // 调整刻度标签的距离
              fontSize: 10 // 调整刻度标签的字体大小
            },
            detail: {
              valueAnimation: true,
              formatter: '{value} km/h',
              color: 'inherit',
              fontSize: 12 // 调整仪表盘数据的字体大小
            },
            data: [{ value: 70 }]
          }
        ]
      };

      this.myChart.setOption(option);

      setInterval(() => {
        this.myChart.setOption({
          series: [
            {
              data: [{ value: +(Math.random() * 100).toFixed(2) }]
            }
          ]
        });
      }, 2000);
    }
  },
  beforeDestroy() {
    if (this.myChart) {
      this.myChart.dispose();
    }
  }
};
</script>

<style scoped>
.echarts-gauge {
  width: 150px; /* 设置图表宽度 */
  height: 150px; /* 设置图表高度 */
}
</style>
